草庐IT

PHP in_array 通配符匹配

全部标签

ruby - 如何在遍历数组时使用 Array#delete?

我有一个数组,我想遍历并删除一些元素。这不起作用:a=[1,2,3,4,5]a.eachdo|x|nextifx[1,2,4]我希望a为[1,2]。我该如何解决这个问题? 最佳答案 a.delete_if{|x|x>=3}参见方法文档here更新:您可以在block中处理x:a.delete_ifdo|element|ifelement>=3do_something_with(element)true#Makesuretheifstatementreturnstrue,soitgetsmarkedfordeletionendend

arrays - 传递 block 时 Array#sort 如何工作?

我在理解array.sort{|x,y|的方式时遇到问题block}工作正常,因此如何使用它?来自Rubydocumentation的示例:a=["d","a","e","c","b"]a.sort#=>["a","b","c","d","e"]a.sort{|x,y|yx}#=>["e","d","c","b","a"] 最佳答案 在你的例子中a.sort相当于a.sort{|x,y|xy}如您所知,要对数组进行排序,您需要能够比较其元素(如果您怀疑这一点,只需尝试在不使用任何比较的情况下实现任何排序算法,不是、>、或>=)。您提

ruby - 检查字符串是否与 ruby​​ 中的正则表达式匹配的最快方法?

检查字符串是否与Ruby中的正则表达式匹配的最快方法是什么?我的问题是我必须“egrep”一个巨大的字符串列表以找到哪些匹配运行时给定的正则表达式。我只关心字符串是否匹配正则表达式,不关心匹配到哪里,也不关心匹配组的内容是什么。我希望这个假设可以用来减少我的代码花在匹配上的时间正则表达式。我加载正则表达式pattern=Regexp.new(ptx).freeze我发现string=~pattern比string.match(pattern)稍快。是否有其他技巧或快捷方式可用于使此测试更快? 最佳答案 从Ruby2.4.0开始,您可

ruby - Ruby 正则表达式是否有像 Perl 中的 "!~"这样的不匹配运算符?

我只想知道ruby​​正则表达式是否有不匹配运算符,就像!~一样在perl中。感觉用起来不方便(?!xxx)或(?因为你不能在xxx中使用正则表达式模式部分。 最佳答案 是的:!~工作得很好——你可能认为它不会因为it’smissingfromthedocumentationpageofRegexp.尽管如此,它还是有效的:irb(main):001:0>'x'!~/x/=>falseirb(main):002:0>'x'!~/y/=>true 关于ruby-Ruby正则表达式是否有像P

ruby - Ruby 的 Array#shift 有什么作用?

我很难理解Array类的shift和unshift方法在Ruby中的作用。有人可以帮助我了解他们的工作吗? 最佳答案 查看RubyDocumentationArray.shift从数组中移除第一个元素并返回它a=[1,2,3]putsa.shift=>1putsa=>[2,3]Unshift将提供的值添加到数组的前面,将所有其他元素向上移动一个a=%w[bcd]=>["b","c","d"]a.unshift("a")=>["a","b","c","d"] 关于ruby-Ruby的Arr

ruby - Array#each 与 Array#map

hash={"d"=>[11,22],"f"=>[33,44,55]}#case1hash.map{|k,vs|vs.map{|v|"#{k}:#{v}"}}.join(",")=>"d:11,d:22,f:33,f:44,f:55"#case2hash.map{|k,vs|vs.each{|v|"#{k}:#{v}"}}.join(",")=>"11,22,33,44,55"唯一的区别是案例1使用vs.map,案例2使用vs.each。这里发生了什么? 最佳答案 Array#each为数组的每个元素执行给定的block,然后返回数

ruby-on-rails - ActiveRecord.find(array_of_ids),保留顺序

当您在Rails中执行Something.find(array_of_ids)时,结果数组的顺序不取决于array_of_ids的顺序。有什么办法可以找到并保留顺序吗?ATM我根据ID的顺序手动对记录进行排序,但这有点蹩脚。UPD:如果可以使用:order参数和某种SQL子句指定顺序,那么如何? 最佳答案 奇怪的是,没有人提出这样的建议:index=Something.find(array_of_ids).group_by(&:id)array_of_ids.map{|i|index[i].first}除了让SQL后端执行它之外,尽

ruby - 返回 Ruby 正则表达式的第一个匹配项

我正在寻找一种在Ruby中对字符串执行正则表达式匹配并使其在第一个匹配项时短路的方法。我正在处理的字符串很长,从标准方式(match方法)来看,它会处理整个字符串,收集每个匹配项,并返回一个包含所有匹配项的MatchData对象。match=string.match(/regex/)[0].to_s 最佳答案 你可以试试String#[](如variableName[/regularexpression/])。这是IRB的示例输出:names="erikkallejohananderserikkallejohananders"#=>

ruby - 如何通过匹配 Capybara 中元素的精确文本来查找元素

我在HTML中有以下两个元素BerlinBerlinGermany我正在尝试使用以下Capybara方法查找元素find("a",:text=>"berlin")上面将返回两个元素,因为它们都包含文本berlin。有没有办法在Capybara中精确匹配文本? 最佳答案 使用正则表达式而不是字符串作为:text键的值:find("a",:text=>/\ABerlin\z/)查看方法的“选项哈希”部分:Capybara::Node::Finders#alldocumentation.PS:文本匹配是区分大小写的。您的示例代码实际上引发

Ruby 正则表达式组匹配,在 1 行上分配变量

我目前正在尝试将一个字符串转换为多个变量。示例字符串:ryan_string="RyanOnRails:Thisisatest"我已将其与此正则表达式匹配,分为3组:ryan_group=ryan_string.scan(/(^.*)(:)(.*)/i)现在要访问每个组,我必须执行如下操作:ryan_group[0][0](firstgroup)RyanOnRailsryan_group[0][1](secondgroup):ryan_group[0][2](thirdgroup)Thisisatest这看起来很荒谬,感觉我做错了什么。我希望能够做这样的事情:g1,g2,g3=ryan